草庐IT

MongoDb 查询 - 计数 + where 条件

全部标签

ruby-on-rails - 如何在 Rails 控制台中查看 MySQL 查询

这个问题在这里已经有了答案:HowtoshowSQLqueriesrunintheRailsconsole?(8个答案)关闭8年前。有没有办法在Rails控制台中查看从ActiveRecord触发了哪些MySQL查询?

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir

ruby-on-rails - 如何在 rails 中按行计数?

当我使用User.count(:all,:group=>"name")时,我得到了多行,但这不是我想要的。我想要的是行数。我怎样才能得到它? 最佳答案 当前(18.03.2014-Rails4.0.3)这是正确的语法:Model.group("field_name").count它返回以计数为值的散列例如SurveyReport.find(30).reports.group("status").count#=>{"pdf_generated"=>56} 关于ruby-on-rails-如

ruby-on-rails - 在 RSpec 单元测试中模拟竞争条件

我们有一个异步任务,它为一个对象执行一个可能长时间运行的计算。然后将结果缓存在对象上。为了防止多个任务重复相同的工作,我们添加了带有原子SQL更新的锁定:UPDATEobjectsSETlocked=1WHEREid=1234ANDlocked=0加锁只针对异步任务。对象本身仍可由用户更新。如果发生这种情况,旧版本对象的任何未完成任务都应丢弃其结果,因为它们可能已过时。使用原子SQL更新也很容易做到这一点:UPDATEobjectsSETresults='...'WHEREid=1234ANDversion=1如果对象已更新,其版本将不匹配,因此结果将被丢弃。这两个原子更新应该处理任何

ruby-on-rails - 将参数值传递给 redirect_to 作为 rails 中的查询字符串

这应该很简单,但我似乎找不到简单的答案。如何将当前请求的参数值传递到redirect_to调用中?我有一些表单值想传递到GET重定向的查询字符串中我想做这样的事情:redirect_to@thing,:foo=>params[:foo]并发送到:http://things/4?[foo][key1]=val1&[foo][key2]=val2谢谢!此外-对于redirect_to:back如何处理?redirect_to:back,:foo=>params[:foo] 最佳答案 redirect_to的“记录”形式仅将第二个参数用于

ruby - 检查数组的任何元素是否满足条件

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:checkifvalueexistsinarrayinRuby我有一个循环遍历字符串数组并在任何字符串包含字符串“狗”时返回true的方法。它正在工作,但多个return语句看起来很乱。有没有更Eloquent方式来做到这一点?defhas_dog?(acct)[acct.title,acct.description,acct.tag].eachdo|text|returntrueiftext.include?("dog")endreturnfalseend

ruby-on-rails - 如何使用 AREL 执行条件 where 子句

如何做一个有条件的where子句?我有一个运行查询的rake任务。假设我正在构建这样的查询:residentials=Residential.where(:is_active=>true)现在,如果我将某个参数传递给rake任务,我想添加到where子句中。我在想这样的事情:residentials.where(:something_else=>true)ifparam_was_passed但这只是替换了现有的where子句。如何将它添加到现有的where子句中? 最佳答案 可以链接where语句residentials=Resid

ruby-on-rails - 带有委托(delegate)和条件的事件记录

是否可以在您的ActiveRecord模型中使用委托(delegate)并在其上使用类似:if的条件?classUser:master,:if=>:has_master?belongs_to:master,:class_name=>"User"defhas_master?master.present?endend 最佳答案 不,你不能,但你可以传递:allow_nil=>true选项以在master为nil时返回nil。classUser:master,:allow_nil=>true#...enduser.master=nilus

ruby-on-rails - 有没有办法使 before_save 成为条件?

我正在尝试在Rails应用程序中进行有条件的before_save,但它似乎不起作用。before_savemethod_call_to_runifself.related_model.some_method_that_returns_t_or_f?如果“some_method_that_returns_t_or_f”返回true,我希望它在保存对象之前运行该方法,否则我只希望它忽略before_save。 最佳答案 你可以使用:ifbefore_savedo_something,:if=>Proc.new{|model|model

ruby - 如何消除分配分支条件下的 Rubocop 警告?

我想关闭特定的Rubocop警告:AssignmentBranchConditionsizeforplot_defaultsistoohigh.[21.05/15]在注释行的代码中执行此操作的适当语法是什么,例如:#rubocop:disable 最佳答案 我相信这是Metrics/AbcSizecop.的消息#rubocop:disableMetrics/AbcSize 关于ruby-如何消除分配分支条件下的Rubocop警告?,我们在StackOverflow上找到一个类似的问题: